package com.maxlen.common.utils;

import io.jsonwebtoken.Claims;
import io.jsonwebtoken.Jws;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.springframework.util.StringUtils;
import java.util.Date;

/**
 * Jwt 生成工具类
 */
public class JwtUtils {

    public static final long EXPIRE = 1000 * 60 * 60 * 1;//token过期时间   24小时
    public static final String APP_SECRET = "ukc8BDbRigUDaY6pZFfWus2jZWLPHO";//密钥


    public static String getJwtToken(String id, String account){

        String JwtToken = Jwts.builder()
                .setHeaderParam("typ", "JWT")
                .setHeaderParam("alg", "HS256")
                .setSubject("jacob-user")
                .setIssuedAt(new Date())
                .setExpiration(new Date(System.currentTimeMillis() + EXPIRE))
                .claim("id", id)
                .claim("account", account)
                .signWith(SignatureAlgorithm.HS256, APP_SECRET)
                .compact();

        return JwtToken;
    }

    /**
     * 根据token，判断token是否存在与有效
     * @param jwtToken
     * @return
     */
    public static boolean checkToken(String jwtToken) {
        if(!StringUtils.hasText(jwtToken)) return false;
        try {
            Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
        } catch (Exception e) {
//            e.printStackTrace();
            return false;
        }
        return true;
    }

//    /**
//     * 根据request判断token是否存在与有效（也就是把token取出来罢了）
//     * @param request
//     * @return
//     */
//    public static boolean checkToken(HttpServletRequest request) {
//        try {
//            String jwtToken = request.getHeader("token");
//            if(!StringUtils.hasText(jwtToken)) return false;
//            Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
//        } catch (Exception e) {
//            e.printStackTrace();
//            return false;
//        }
//        return true;
//    }
//
//    /**
//     * 根据token获取会员id
//     * @param request
//     * @return
//     */
//    public static String getMemberIdByJwtToken(HttpServletRequest request) {
//        String jwtToken = request.getHeader("token");
//        if(!StringUtils.hasText(jwtToken)) return "";
//        try {
//            // 这里解析可能会抛异常，所以try catch来捕捉
//            Jws<Claims> claimsJws = Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
//            Claims claims = claimsJws.getBody();
//            return (String)claims.get("id");
//        }catch (Exception e){
//            e.printStackTrace();
//            return "";
//        }
//    }
//
//
//    /**
//     * 根据token获取用户的account
//     * @param request
//     * @return
//     */
//    public static String getMemberAccountByJwtToken(HttpServletRequest request) {
//        String jwtToken = request.getHeader("token");
//        if(!StringUtils.hasText(jwtToken)) return "";
//        try{
//            Jws<Claims> claimsJws = Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
//            Claims claims = claimsJws.getBody();
//            return (String)claims.get("account");
//        }catch (Exception e){
//            e.printStackTrace();
//            return "";
//        }
//    }

    /**
     * 根据token获取会员id
     * @param jwtToken
     * @return
     */
    public static String getMemberIdByJwtToken(String jwtToken) {
        if(!StringUtils.hasText(jwtToken)) return "";
        try {
            // 这里解析可能会抛异常，所以try catch来捕捉
            Jws<Claims> claimsJws = Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
            Claims claims = claimsJws.getBody();
            return (String)claims.get("id");
        }catch (Exception e){
            e.printStackTrace();
            return "";
        }
    }


    /**
     * 根据token获取用户的account
     * @param jwtToken
     * @return
     */
    public static String getMemberAccountByJwtToken(String jwtToken) {
        if(!StringUtils.hasText(jwtToken)) return "";
        try{
            Jws<Claims> claimsJws = Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
            Claims claims = claimsJws.getBody();
            return (String)claims.get("account");
        }catch (Exception e){
            e.printStackTrace();
            return "";
        }
    }
}
